gint count);
static gint gtk_tree_view_unref_and_check_selection_tree (GtkTreeView *tree_view,
GtkRBTree *tree);
-static void gtk_tree_view_queue_draw_path (GtkTreeView *tree_view,
- GtkTreePath *path,
- const GdkRectangle *clip_rect);
-static void gtk_tree_view_queue_draw_arrow (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node);
static void gtk_tree_view_snapshot_arrow (GtkTreeView *tree_view,
GtkSnapshot *snapshot,
GtkRBTree *tree,
{
tree_view->priv->button_pressed_node = tree_view->priv->prelight_node;
tree_view->priv->button_pressed_tree = tree_view->priv->prelight_tree;
- gtk_tree_view_queue_draw_arrow (tree_view,
- tree_view->priv->prelight_tree,
- tree_view->priv->prelight_node);
+ gtk_widget_queue_draw (widget);
}
grab_focus_and_unset_draw_keyfocus (tree_view);
else
tree_view->priv->arrow_prelit = FALSE;
- gtk_tree_view_queue_draw_arrow (tree_view, tree, node);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
}
{
tree_view->priv->arrow_prelit = FALSE;
- gtk_tree_view_queue_draw_arrow (tree_view,
- tree_view->priv->prelight_tree,
- tree_view->priv->prelight_node);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
- _gtk_tree_view_queue_draw_node (tree_view,
- tree_view->priv->prelight_tree,
- tree_view->priv->prelight_node,
- NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
{
tree_view->priv->arrow_prelit = TRUE;
- gtk_tree_view_queue_draw_arrow (tree_view, tree, node);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
GTK_RBNODE_SET_FLAG (node, GTK_RBNODE_IS_PRELIT);
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (tree_view->priv->hover_expand)
{
GTK_RBNODE_UNSET_FLAG (start_node, GTK_RBNODE_IS_SELECTED);
}
- _gtk_tree_view_queue_draw_node (tree_view, start_tree, start_node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
node_not_selectable:
if (start_node == end_node)
if (tree_view->priv->rubber_band_start_node)
{
GtkRBNode *node = tree_view->priv->rubber_band_start_node;
- GtkRBTree *tree = tree_view->priv->rubber_band_start_tree;
if (tree_view->priv->rubber_band_modify)
{
else
GTK_RBNODE_UNSET_FLAG (node, GTK_RBNODE_IS_SELECTED);
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
}
if (!tree_view->priv->rubber_band_start_node || !start_node)
tree_view->priv->rubber_band_end_node = end_node;
}
-static void
-gtk_tree_view_invalidate_bin_region (GtkTreeView *tree_view,
- cairo_region_t *region)
-{
- gtk_widget_queue_draw (GTK_WIDGET (tree_view));
-}
-
-static void
-gtk_tree_view_invalidate_bin_area (GtkTreeView *tree_view,
- const GdkRectangle *rect)
-{
- gtk_tree_view_invalidate_bin_region (tree_view, NULL);
-}
-
static void
gtk_tree_view_update_rubber_band (GtkTreeView *tree_view)
{
gdouble start_x, start_y, offset_x, offset_y, x, y;
- GdkRectangle old_area;
- GdkRectangle new_area;
- cairo_region_t *invalid_region;
gint bin_x, bin_y;
if (!gtk_gesture_is_recognized (tree_view->priv->drag_gesture))
return;
- old_area.x = MIN (tree_view->priv->press_start_x, tree_view->priv->rubber_band_x);
- old_area.y = MIN (tree_view->priv->press_start_y, tree_view->priv->rubber_band_y) - tree_view->priv->dy;
- old_area.width = ABS (tree_view->priv->rubber_band_x - tree_view->priv->press_start_x) + 1;
- old_area.height = ABS (tree_view->priv->rubber_band_y - tree_view->priv->press_start_y) + 1;
-
gtk_gesture_drag_get_offset (GTK_GESTURE_DRAG (tree_view->priv->drag_gesture),
&offset_x, &offset_y);
gtk_gesture_drag_get_start_point (GTK_GESTURE_DRAG (tree_view->priv->drag_gesture),
x = MAX (bin_x + offset_x, 0);
y = MAX (bin_y + offset_y, 0);
- new_area.x = MIN (tree_view->priv->press_start_x, x);
- new_area.y = MIN (tree_view->priv->press_start_y, y) - tree_view->priv->dy;
- new_area.width = ABS (x - tree_view->priv->press_start_x) + 1;
- new_area.height = ABS (y - tree_view->priv->press_start_y) + 1;
-
- invalid_region = cairo_region_create_rectangle (&old_area);
- cairo_region_union_rectangle (invalid_region, &new_area);
-
- gtk_tree_view_invalidate_bin_region (tree_view, invalid_region);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
tree_view->priv->rubber_band_x = x;
tree_view->priv->rubber_band_y = y;
GtkTreeView *tree_view)
{
if (tree_view->priv->prelight_node)
- _gtk_tree_view_queue_draw_node (tree_view,
- tree_view->priv->prelight_tree,
- tree_view->priv->prelight_node,
- NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
tree_view->priv->event_last_x = -10000;
tree_view->priv->event_last_y = -10000;
/* Incremental Reflow
*/
-static void
-gtk_tree_view_node_queue_redraw (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node)
-{
- GdkRectangle rect;
-
- rect.x = 0;
- rect.y =
- _gtk_rbtree_node_find_offset (tree, node)
- - gtk_adjustment_get_value (tree_view->priv->vadjustment);
- rect.width = gtk_widget_get_width (GTK_WIDGET (tree_view));
- rect.height = GTK_RBNODE_GET_HEIGHT (node);
-
- gtk_tree_view_invalidate_bin_area (tree_view, &rect);
-}
-
static gboolean
node_is_visible (GtkTreeView *tree_view,
GtkRBTree *tree,
if (GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) ||
GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_COLUMN_INVALID))
{
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (validate_row (tree_view, tree, node, &iter, path))
size_changed = TRUE;
}
if (GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) ||
GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_COLUMN_INVALID))
{
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (validate_row (tree_view, tree, node, &iter, path))
size_changed = TRUE;
}
if (GTK_RBNODE_FLAG_SET (tmpnode, GTK_RBNODE_INVALID) ||
GTK_RBNODE_FLAG_SET (tmpnode, GTK_RBNODE_COLUMN_INVALID))
{
- _gtk_tree_view_queue_draw_node (tree_view, tmptree, tmpnode, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (validate_row (tree_view, tmptree, tmpnode, &tmpiter, tmppath))
size_changed = TRUE;
}
if (GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) ||
GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_COLUMN_INVALID))
{
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (validate_row (tree_view, tree, node, &iter, path))
size_changed = TRUE;
}
if (GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) ||
GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_COLUMN_INVALID))
{
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (validate_row (tree_view, tree, node, &iter, above_path))
size_changed = TRUE;
}
&& tree_view->priv->fixed_height >= 0)
{
_gtk_rbtree_node_set_height (tree, node, tree_view->priv->fixed_height);
- if (gtk_widget_get_realized (GTK_WIDGET (tree_view)))
- gtk_tree_view_node_queue_redraw (tree_view, tree, node);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
else
{
}
else
{
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
done:
GTK_EVENT_SEQUENCE_CLAIMED);
}
-static void
-gtk_tree_view_queue_draw_arrow (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node)
-{
- GdkRectangle rect;
-
- if (!gtk_widget_get_realized (GTK_WIDGET (tree_view)))
- return;
-
- rect.x = 0;
- rect.width = gtk_tree_view_get_expander_size (tree_view);
- rect.width = MAX (rect.width, tree_view->priv->width);
- rect.width = MAX (rect.width, gtk_widget_get_width (GTK_WIDGET (tree_view)));
-
- rect.y = gtk_tree_view_get_row_y_offset (tree_view, tree, node);
- rect.height = gtk_tree_view_get_row_height (tree_view, node);
-
- gtk_tree_view_invalidate_bin_area (tree_view, &rect);
-}
-
-void
-_gtk_tree_view_queue_draw_node (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node,
- const GdkRectangle *clip_rect)
-{
- GdkRectangle rect;
-
- if (!gtk_widget_get_realized (GTK_WIDGET (tree_view)))
- return;
-
- rect.x = 0;
- rect.width = MAX (tree_view->priv->width, gtk_widget_get_width (GTK_WIDGET (tree_view)));
-
- rect.y = gtk_tree_view_get_row_y_offset (tree_view, tree, node);
- rect.height = gtk_tree_view_get_row_height (tree_view, node);
-
- if (clip_rect)
- {
- GdkRectangle new_rect;
-
- gdk_rectangle_intersect (clip_rect, &rect, &new_rect);
-
- gtk_tree_view_invalidate_bin_area (tree_view, &new_rect);
- }
- else
- {
- gtk_tree_view_invalidate_bin_area (tree_view, &rect);
- }
-}
-
static inline gint
gtk_tree_view_get_effective_header_height (GtkTreeView *tree_view)
{
column);
}
-
-static void
-gtk_tree_view_queue_draw_path (GtkTreeView *tree_view,
- GtkTreePath *path,
- const GdkRectangle *clip_rect)
-{
- GtkRBTree *tree = NULL;
- GtkRBNode *node = NULL;
-
- _gtk_tree_view_find_node (tree_view, path, &tree, &node);
-
- if (tree)
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, clip_rect);
-}
-
/* x and y are the mouse position
*/
static void
{
tree_view->priv->draw_keyfocus = TRUE;
- gtk_tree_view_queue_draw_path (tree_view, cursor_path, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
gtk_tree_path_free (cursor_path);
if (tree_view->priv->focus_column == NULL)
y -= window_y;
gtk_tree_view_scroll_to_point (tree_view, -1, y);
gtk_tree_view_clamp_node_visible (tree_view, cursor_tree, cursor_node);
- _gtk_tree_view_queue_draw_node (tree_view, cursor_tree, cursor_node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (!gtk_tree_path_compare (old_cursor_path, cursor_path))
gtk_widget_error_bell (GTK_WIDGET (tree_view));
if (found_column)
{
if (!gtk_tree_view_has_can_focus_cell (tree_view))
- _gtk_tree_view_queue_draw_node (tree_view,
- tree_view->priv->cursor_tree,
- tree_view->priv->cursor_node,
- NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
g_signal_emit (tree_view, tree_view_signals[CURSOR_CHANGED], 0);
gtk_widget_grab_focus (GTK_WIDGET (tree_view));
}
gtk_tree_view_clamp_node_visible (tree_view, cursor_tree, cursor_node);
gtk_widget_grab_focus (GTK_WIDGET (tree_view));
- _gtk_tree_view_queue_draw_node (tree_view, cursor_tree, cursor_node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
if (!tree_view->priv->extend_selection_pressed)
gtk_tree_view_row_activated (tree_view, cursor_path,
tree_view->priv->cursor_node);
gtk_widget_grab_focus (GTK_WIDGET (tree_view));
- gtk_tree_view_queue_draw_path (tree_view, cursor_path, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
gtk_tree_path_free (cursor_path);
return TRUE;
if (tree_view->priv->cursor_tree->parent_node)
{
- gtk_tree_view_queue_draw_path (tree_view, cursor_path, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
gtk_tree_path_up (cursor_path);
tree_view->priv->cursor_tree,
tree_view->priv->cursor_node,
GTK_CELL_RENDERER_FOCUSED);
- _gtk_tree_view_queue_draw_node (tree_view,
- tree_view->priv->cursor_tree,
- tree_view->priv->cursor_node,
- NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
/* One cannot set the cursor on a separator. Also, if
gtk_tree_view_clamp_node_visible (tree_view,
tree_view->priv->cursor_tree,
tree_view->priv->cursor_node);
- _gtk_tree_view_queue_draw_node (tree_view,
- tree_view->priv->cursor_tree,
- tree_view->priv->cursor_node,
- NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
_gtk_tree_view_accessible_add_state (tree_view,
{
tree_view->priv->drag_dest_row =
gtk_tree_row_reference_new_proxy (G_OBJECT (tree_view), tree_view->priv->model, path);
- gtk_tree_view_queue_draw_path (tree_view, path, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
}
else
tree_view->priv->drag_dest_row = NULL;
if (current_dest)
{
- GtkRBTree *tree, *new_tree;
- GtkRBNode *node, *new_node;
-
- _gtk_tree_view_find_node (tree_view, current_dest, &tree, &node);
- _gtk_tree_view_queue_draw_node (tree_view, tree, node, NULL);
-
- if (tree && node)
- {
- _gtk_rbtree_next_full (tree, node, &new_tree, &new_node);
- if (new_tree && new_node)
- _gtk_tree_view_queue_draw_node (tree_view, new_tree, new_node, NULL);
+ gtk_widget_queue_draw (GTK_WIDGET (tree_view));
- _gtk_rbtree_prev_full (tree, node, &new_tree, &new_node);
- if (new_tree && new_node)
- _gtk_tree_view_queue_draw_node (tree_view, new_tree, new_node, NULL);
- }
gtk_tree_path_free (current_dest);
}
}